| Name:   | • | EE-272L Digital Systems Design |
|---------|---|--------------------------------|
| Reg. No |   | Marks Obtained:                |

# Lab Manual

# **DSD Lab Manual Evaluation Rubrics**

| Assessment           | Total<br>Marks | Marks<br>Obtained | 0-30%                                                                                                      | 30-60%                                                                                                     | 70-100%                                                                                              |
|----------------------|----------------|-------------------|------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|
| Code<br>Organization | 3              |                   | No Proper<br>Indentation and<br>descriptive<br>naming, no code<br>organization.                            | Proper<br>Indentation or<br>descriptive<br>naming or code<br>organization.                                 | Proper<br>Indentation and<br>descriptive<br>naming, code<br>organization.                            |
|                      |                |                   | Zero to Some<br>understanding but<br>not working                                                           | Mild to Complete<br>understanding but<br>not working                                                       | Complete understanding, and proper working                                                           |
| Simulation           | 5              |                   | Simulation not<br>done or incorrect,<br>without any<br>understanding of<br>waveforms                       | Working simulation with errors, don't cares's(x) and high impedance(z), partial understanding of waveforms | Working<br>simulation<br>without any<br>errors, etc and<br>complete<br>understanding of<br>waveforms |
| FPGA                 | 2              |                   | Not implemented<br>on FPGA and<br>questions related<br>to synthesis and<br>implementation<br>not answered. | Correctly Implemented on FPGA or questions related to synthesis and implementation answered.               | Correctly Implemented on FPGA and questions related to synthesis and implementation answered.        |

#### Lab Task

For this lab, you are required to create a module containing two 2-bits inputs a and b such that we observe the following output on the tri-color LED.

$$F = \begin{cases} a > b & Cyan \\ a = b & Purple \\ a < b & Yellow \end{cases}$$

For this purpose, first develop the truth table according to the requirement and then get the minimized expression for the output using K-maps. Next, implement the design on Vivado.

#### **Deliverables**

#### a) Truth table:

|    | а | a0 | b | b0 | R | G | В |
|----|---|----|---|----|---|---|---|
|    |   |    |   |    |   |   |   |
| 0  | 0 | 0  | 0 | 0  | 1 | 0 | 1 |
| 1  | 0 | 0  | 0 | 1  | 1 | 1 | 0 |
| 2  | 0 | 0  | 1 | 0  | 1 | 1 | 0 |
| 3  | 0 | 0  | 1 | 1  | 1 | 1 | 0 |
| 4  | 0 | 1  | 0 | 0  | 0 | 1 | 1 |
| 5  | 0 | 1  | 0 | 1  | 1 | 0 | 1 |
| 6  | 0 | 1  | 1 | 0  | 1 | 1 | 0 |
| 7  | 0 | 1  | 1 | 1  | 1 | 1 | 0 |
| 8  | 1 | 0  | 0 | 0  | 0 | 1 | 1 |
| 9  | 1 | 0  | 0 | 1  | 0 | 1 | 1 |
| 10 | 1 | 0  | 1 | 0  | 1 | 0 | 1 |
| 11 | 1 | 0  | 1 | 1  | 1 | 1 | 0 |
| 12 | 1 | 1  | 0 | 0  | 0 | 1 | 1 |
| 13 | 1 | 1  | 0 | 1  | 0 | 1 | 1 |
| 14 | 1 | 1  | 1 | 0  | 0 | 1 | 1 |
| 15 | 1 | 1  | 1 | 1  | 1 | 0 | 1 |

# d) Circuit diagram inferred by the Xilinx Vivado:



#### e) Maximum Combinational delay:



# f) Utilization Report:

| es Netl    | 26<br>27<br>28<br>29<br>30 | 1. Slice Logic        |     |    |     |           |       |   |  |
|------------|----------------------------|-----------------------|-----|----|-----|-----------|-------|---|--|
| Properties | 31                         | Site Type             |     |    | ed  | Available | Util% |   |  |
| File P     | 33                         | Slice LUTs*           | . 2 |    | 0   | 63400     | <0.01 | i |  |
|            | 34                         | LUT as Logic          | 2   | 1  | 0 [ | 63400     | <0.01 |   |  |
| Source     | 35                         | LUT as Memory         | 1 0 | I  | 0 [ | 19000     | 0.00  | I |  |
| S          | 36                         | Slice Registers       | 1 0 | 1  | 0 [ | 126800    | 0.00  | I |  |
| -          | 37                         | Register as Flip Flop | 0   | 1  | 0 [ | 126800    | 0.00  | Ī |  |
|            | 38                         | Register as Latch     | 1 0 | 1  | 0 [ | 126800    | 0.00  | Ī |  |
|            | 39                         | F7 Muxes              | 0   | 1  | 0 [ | 31700     | 0.00  | ı |  |
|            | 40                         | F8 Muxes              | 0   | 1  | 0   | 15850     | 0.00  | Ī |  |
|            | 41                         | +                     | +   | -+ | +   |           | +     | + |  |

# **System Verilog code:**

```
T:\Notepad++\Projects\new 2.v - Notepad++
File Edit Search View Encoding Language Settings Tools Macro Run Plugins Window ?
🕽 🖶 🗎 🖺 🥦 🕞 🖟 🖺 🕹 🐚 🖺 🕽 🗲 🛗 🦠 😝 😭 🖳 🚍 🖺 🏗 🔞 🚳 🗗 🗩 🗀 📀 🗩
🖶 Lab2_tb.v 🔀 📙 Lab2.v 🔀 📙 Full_adder.v 🔀 📙 Full_adder_tb.v 🔀 📙 new 1.v 🔀 📙 new 2.v 🔀
         module Lab4(a,a0,b,b0,R,G,B);
  2
         input a,a0,b,b0;
  3
         output R,G,B;
  4
      assign R = (~a0 & b)|(b & b0)|(~a0 & ~a)|(~a & b0)|(~a0 & ~a);
  5
         assign G = (a & \sim b) | (\sim a & b) | (\sim a 0 & b 0) | (a 0 & \sim b 0);
         assign B = (\sim b \& \sim b0) | (a \& a0) | (a0 \& \sim b) | (a \& \sim b) | (a \& \sim b0);
  6
  7
         endmodule
  8
```